<template>
  <!-- 公共导入组件 -->
  <upload-excel :on-success="success" />
</template>

<script>
import { importEmployee } from '@/api/employees'
export default {
  data() {
    return {
      type: this.$route.query.type
    }
  },
  methods: {
    async success({ header, results }) {
      if (this.type === 'user') {
        const userRelations = {
          '入职日期': 'timeOfEntry',
          '手机号': 'mobile',
          '姓名': 'username',
          '转正日期': 'correctionTime',
          '工号': 'workNumber'
        }

        const arr = results.map(item => {
          const userInfo = {}
          Object.keys(item).forEach(key => {
          // 格式化 入职日期 和 转正日期
            if (userRelations[key] === 'timeOfEntry' || userRelations[key] === 'correctionTime') {
              userInfo[userRelations[key]] = new Date(this.formatDate(item[key], '/'))
            } else {
            // 将中文字段对应的值，转换为英文字段对应的值
              userInfo[userRelations[key]] = item[key]
            }
            // 设置用户所属公司
            userInfo.companyId = this.$store.getters.companyId
            userInfo.companyName = this.$store.getters.companyName
          })
          return userInfo
        })
        console.log(arr)
        // 调用 api 接口
        await importEmployee(arr)
        this.$message.success('导入成功')
        // 退回到上一个页面，员工列表页 /employees
        this.$router.back()
      } else if (this.type === 'company') {
        console.log('处理公司批量导入')
      }
    },
    // 格式化 excel 中的的日期
    formatDate(numb, format) {
      const time = new Date((numb - 1) * 24 * 3600000 + 1)
      time.setYear(time.getFullYear() - 70)
      const year = time.getFullYear() + ''
      const month = time.getMonth() + 1 + ''
      const date = time.getDate() - 1 + ''
      if (format && format.length === 1) {
        return year + format + month + format + date
      }
      return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
    }
  }
}
</script>

